package com.ssm.controller;

import java.util.Date;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.SessionAttributes;

import com.ssm.po.User;
import com.ssm.service.AdminService;
import com.ssm.service.UserService;

/**
 * ***********用户基本************** 用户登录 * 用户注册*
 * 
 * 用户信息更新* 用户密码更新*
 * 
 * @author
 *
 */
@Controller
@SessionAttributes({ "nowuser" })
@RequestMapping(value = "user/")
public class UserController {

    @Resource(name = "userService")
    public UserService userService;

    @Resource(name = "adminService")
    public AdminService adminService;

    // 登录
    @RequestMapping("login.do")
    public String login(String studentid, String password, Model model) {

        User user = null;

        user = userService.login(studentid);

        if (user == null) {
            model.addAttribute("msg", "登录失败--请确定账号和密码正确");
            return "login";
        }

        if (password.equals(user.getPassword())) {
            model.addAttribute("nowuser", user);
            model.addAttribute("loginflag", "loginflag");//
            return "index";
        } else {
            model.addAttribute("msg", "登录失败--请确定账号和密码正确");
            return "login";
        }

    }

    // 注册
    @RequestMapping("register.do")
    public String register(User user, Model model) {

        // 检查学号账号重复
        int countnum = userService.getAccountCount(user.getStudentid());
        if (countnum > 0) {
            model.addAttribute("msg", "该学号已经注册");
            model.addAttribute("user", user);
            return "register";
        }
        System.out.println(22);
        user.setStuid(0);
        user.setRegistertime(new Date());
        user.setMoney(0.00);
        user.setState(2);
        user.setVerify(0);
        System.out.println(user.toString());

        int result = userService.setUser(user);

        if (result <= 0) {
            model.addAttribute("msg", "提交失败");
            model.addAttribute("user", user);
            return "register";
        }

        model.addAttribute("msg", "提交成功，请等待管理员审核，后续会有短信通知。");

        return "login";
    }

    // 更新
    @RequestMapping("update.do")
    public String update(HttpServletRequest request, User user, Model model) {
        int r = userService.updateUserInfo(user);
        if (r > 0) {
            model.addAttribute("msg", "更新成功，请重新登录");
            model.addAttribute("flag", "更新成功，请重新登录");
            return "userUpdate";
        }
        model.addAttribute("msg", "更新失败");
        return "userUpdate";
    }

    // 更新
    @RequestMapping("updatepwd.do")
    public String updatepwd(HttpServletRequest request, String oldpassword, User user, Model model) {

        User olduser = (User) request.getSession(false).getAttribute("nowuser");

        System.out.println(olduser.getPassword());
        System.out.println(oldpassword);
        if (!olduser.getPassword().equals(oldpassword)) {
            model.addAttribute("msg", "原密码错误");
            return "userPassword";
        }

        int r = userService.updateUserInfo(user);
        if (r > 0) {
            model.addAttribute("msg", "修改成功，请重新登录");
            model.addAttribute("flag", "更新成功，请重新登录");
            return "userPassword";
        }
        model.addAttribute("msg", "修改失败");
        return "userPassword";
    }

}
